# **LAB 3 Report**

Name: Hyokwon Chung, Rishi Jarral

UT EID: hc27426, rsj647

Section: 17540, 17508

# **Checklist:**

## Part 1 -

i. Waveform of the structural AND gate (Just the uncommented portion)



```
ii. Constraint File (Just the uncommented portion)
## Switches
iii. set_property PACKAGE_PIN V17 [get_ports {b}]
iv. set_property IOSTANDARD LVCMOS33 [get_ports {b}]
v. set_property PACKAGE_PIN V16 [get_ports {a}]
vi. set_property IOSTANDARD LVCMOS33 [get_ports {a}]
vii.
viii.
ix. ## LEDs
```

x. set\_property PACKAGE\_PIN U16 [get\_ports {out}]

#### Part 2 -

iii. Constraint File (Just the uncommented portion) set\_property PACKAGE\_PIN V17 [get\_ports {c}] set property IOSTANDARD LVCMOS33 [get\_ports {c}] set property PACKAGE PIN V16 [get ports {b}] set\_property IOSTANDARD LVCMOS33 [get\_ports {b}] set\_property PACKAGE\_PIN W16 [get\_ports {a}] set property IOSTANDARD LVCMOS33 [get\_ports {a}] set\_property PACKAGE\_PIN W17 [get\_ports {sw[3]}] set property IOSTANDARD LVCMOS33 [get\_ports {sw[3]}] ## LEDs set property PACKAGE PIN U16 [get ports {d0}] set property IOSTANDARD LVCMOS33 [get ports {d0}] set property PACKAGE PIN E19 [get ports {d1}] set property IOSTANDARD LVCMOS33 [get\_ports {d1}] set\_property PACKAGE\_PIN U19 [get\_ports {d2}] set property IOSTANDARD LVCMOS33 [get\_ports {d2}] set\_property PACKAGE\_PIN V19 [get\_ports {d3}] set property IOSTANDARD LVCMOS33 [get\_ports {d3}] set\_property PACKAGE\_PIN W18 [get\_ports {d4}] set property IOSTANDARD LVCMOS33 [get ports {d4}] set property PACKAGE PIN U15 [get ports {d5}] set property IOSTANDARD LVCMOS33 [get\_ports {d5}] set\_property PACKAGE\_PIN U14 [get\_ports {d6}] set property IOSTANDARD LVCMOS33 [get\_ports {d6}] set property PACKAGE PIN V14 [get ports {d7}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {d7}]

#### Part 3 -

- iv. Truth Table of the function
- v. K-maps showing minimization of the logic functions (outputs)
- vi. Algebraic expression of the minimized logic functions (outputs)
- vii. Verilog codes of module and testbench for structural modelling
- viii. Simulation waveform for structural modelling
- ix. Constraint File (Just the uncommented portion)

**Note** The Verilog codes and the uncommented portions of the constraint files should be copied in your lab report and the actual Verilog (.v) and Constraint (.xdc) files need to be zipped and submitted as well on Canvas. You are not allowed to change your Verilog codes after final submission as the TAs may download the submitted codes from Canvas during checkouts. For the truth Table, K-maps minimizations and algebraic expressions, you are free to draw them on paper and then put the pictures in your lab report, but please make sure it is legible for the TAs to grade it properly.

Part3 IV & V & VI (TT, K-map, Equations)

| Hydren an<br>Right Java                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | hosnaze<br>rsj647                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| A B C D  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 0 0  0 0 | abcdefg 5WT07-A  1111100000 2-C  11011000 3-B  1111001 10000 1011011000 10011111000 100111111 |
| A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 8                                                                                             |



## Part3 - VI Verliog code

`timescale 1ns / 1ps

```
module lcd(
  input [3:0] sw,
  output AN3, AN2, AN1, AN0,
  output[6:0] seg,
  output dp
 );
 assign AN3 = 1;
 assign AN2 = 1;
 assign AN1 = 1;
assign AN0 = 0;
                seg[0]=
                                ((~sw[3])&(~sw[2])&(~sw[1])&sw[0])
assign
((~sw[3])&sw[2]&(~sw[1])&(~sw[0]));
assign
                seg[1]=
                                   ((\sim sw[3])\&sw[2]\&(\sim sw[1])\&sw[0])
((~sw[3])&sw[2]&sw[1]&(~sw[0]));
```

```
assign seg[2] = ((\sim sw[3]) \& (\sim sw[2]) \& sw[1] \& (\sim sw[0]));
assign
                                                                                seg[3] = ((^sw[3])&(^sw[2])&(^sw[1])&sw[0])
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         1
((\sim sw[3])\&sw[2]\&(\sim sw[1])\&(\sim sw[0])) \mid ((\sim sw[3])\&sw[2]\&sw[1]\&sw[0]);
assign seg[4] = ((^sw[3])\&sw[0]) | ((^sw[3])\&sw[2]\&(^sw[1]))
(~(sw[2])&(~sw[1])&sw[0]);
assign seg[5] = ((\sim sw[3])\&(\sim sw[2])\&sw[0]) / ((\sim sw[3])\&(\sim sw[2])\&sw[1]) / ((\sim sw[3])\&sw[1]) / ((\sim sw[3
((~sw[3])&sw[1]&sw[0]);
assign\ seg[6] = ((\sim sw[3])\&(\sim sw[2])\&(\sim sw[1]))/((\sim sw[3])\&sw[2]\&sw[1]\&sw[0]);
assign dp = 1;
```

endmodule

# Part3 - VI tb

```
`timescale 1ns / 1ps
module tb_lcd;
  reg [3:0] SW;
  wire [6:0]seg;
  wire ANO;
  wire AN1;
  wire AN2;
  wire AN3;
  Icd uut (
      .sw(SW),
      .seg(seg),
      .ANO(ANO),
      .AN1(AN1),
      .AN2(AN2),
      .AN3(AN3)
 );
  initial begin
  #50;
          // initial wait
```

// Iterate through all values 0-9

SW[0] = 1'b0;

SW[1] = 1'b0;

SW[2] = 1'b0;

SW[3] = 1'b0;

*#50;* 

SW[0] = 1'b0;

SW[1] = 1'b0;

SW[2] = 1'b0;

SW[3] = 1'b1;

*#50;* 

SW[0] = 1'b0;

SW[1] = 1'b0;

SW[2] = 1'b1;

SW[3] = 1'b0;

#50;

SW[0] = 1'b0;

$$SW[1] = 1'b0;$$

$$SW[2] = 1'b1;$$

$$SW[3] = 1'b1;$$

#50;

$$SW[0] = 1'b0;$$

$$SW[1] = 1'b1;$$

$$SW[2] = 1'b0;$$

$$SW[3] = 1'b0;$$

*#50;* 

$$SW[0] = 1'b0;$$

$$SW[2] = 1'b0;$$

$$SW[3] = 1'b1;$$

#50;

$$SW[0] = 1'b0;$$

$$SW[1] = 1'b1;$$

$$SW[2] = 1'b1;$$

$$SW[3] = 1'b0;$$

*#50;* 

$$SW[0] = 1'b0;$$

$$SW[1] = 1'b1;$$

$$SW[2] = 1'b1;$$

$$SW[3] = 1'b1;$$

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b0;$$

$$SW[2] = 1'b0;$$

$$SW[3] = 1'b0;$$

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b0;$$

$$SW[2] = 1'b0;$$

$$SW[3] = 1'b1;$$

*#50;* 

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b0;$$

$$SW[2] = 1'b1;$$

$$SW[3] = 1'b0;$$

*#50;* 

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b0;$$

$$SW[2] = 1'b1;$$

$$SW[3] = 1'b1;$$

#50;

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b1;$$

$$SW[2] = 1'b0;$$

$$SW[3] = 1'b0;$$

*#50;* 

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b1;$$

$$SW[2] = 1'b0;$$

$$SW[3] = 1'b1;$$

*#50;* 

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b1;$$

$$SW[2] = 1'b1;$$

```
SW[3] = 1'b0;
#50;
```

$$SW[0] = 1'b1;$$

$$SW[1] = 1'b1;$$

$$SW[3] = 1'b1;$$

end

endmodule

# Part3 - VII Waveform



#### Part3 - VIII Constraint file

```
## Clock signal - Uncomment if needed (will be used in future labs)
set_property PACKAGE_PIN W5 [get_ports clk]
set property IOSTANDARD LVCMOS33 [get_ports clk]
create_clock -add -name sys_clk_pin -period 10.00 -waveform {0 5} [get_ports clk]
## Switches
set property PACKAGE PIN V17 [get ports {sw[0]}]
set property IOSTANDARD LVCMOS33 [get_ports {sw[0]}]
set_property PACKAGE_PIN V16 [get_ports {sw[1]}]
set property IOSTANDARD LVCMOS33 [get_ports {sw[1]}]
set_property PACKAGE_PIN W16 [get_ports {sw[2]}]
set property IOSTANDARD LVCMOS33 [get ports {sw[2]}]
set_property PACKAGE_PIN W17 [get_ports {sw[3]}]
set property IOSTANDARD LVCMOS33 [get_ports {sw[3]}]
#7 segment display
set property PACKAGE PIN W7 [get ports {seg[0]}]
set property IOSTANDARD LVCMOS33 [get_ports {seg[0]}]
set property PACKAGE PIN W6 [get ports {seg[1]}]
set property IOSTANDARD LVCMOS33 [get_ports {seg[1]}]
```

```
set_property PACKAGE_PIN U8 [get_ports {seg[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[2]}]
set_property PACKAGE_PIN V8 [get_ports {seg[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[3]}]
set_property PACKAGE_PIN U5 [get_ports {seg[4]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[4]}]
set_property PACKAGE_PIN V5 [get_ports {seg[4]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[5]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[5]}]
set_property PACKAGE_PIN U7 [get_ports {seg[6]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[6]}]
```

set\_property PACKAGE\_PIN V7 [get\_ports dp]
set\_property IOSTANDARD LVCMOS33 [get\_ports dp]

set\_property PACKAGE\_PIN U2 [get\_ports {AN0}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {AN0}]

set\_property PACKAGE\_PIN U4 [get\_ports {AN1}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {AN1}]

set\_property PACKAGE\_PIN V4 [get\_ports {AN2}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {AN2}]

set\_property PACKAGE\_PIN W4 [get\_ports AN3]

set\_property IOSTANDARD LVCMOS33 [get\_ports AN3]